Message Delivery Modes: Persistent এবং Non-persistent

Java Technologies - অ্যাপাচি অ্যাকটিভএমকিউ (Apache ActiveMQ) Apache ActiveMQ এর বেসিক কনসেপ্ট |
140
140

অ্যাপাচি অ্যাকটিভএমকিউ (Apache ActiveMQ) মেসেজ ব্রোকারের মাধ্যমে মেসেজের প্রেরণ এবং গ্রহণের সময়, মেসেজের দীর্ঘস্থায়িতা (Persistence) একটি গুরুত্বপূর্ণ বিষয়। এটি নির্ধারণ করে যে মেসেজগুলি ডিফল্টভাবে কিউ বা টপিকে কতদিন থাকবে এবং সিস্টেম বন্ধ হওয়ার পরও সেগুলি কি সংরক্ষিত থাকবে। অ্যাকটিভএমকিউ মেসেজ ডেলিভারি দুইটি প্রধান মোডে পরিচালনা করে: Persistent এবং Non-persistent


Persistent Message Delivery Mode

Persistent মেসেজ ডেলিভারি মোড নিশ্চিত করে যে মেসেজটি একবার পাঠানো হলে, সেটি ডাটাবেস বা ফাইল সিস্টেমে সেভ হয়ে যাবে এবং ব্রোকারের রিস্টার্ট বা সিস্টেম ক্র্যাশের পরও মেসেজটি হারিয়ে যাবে না। এই মোডে পাঠানো মেসেজগুলি দীর্ঘস্থায়ী (Persistent) হয়ে থাকে এবং তাদের ডেটা সিস্টেম বন্ধ বা ক্র্যাশ হওয়ার পরও পুনরুদ্ধার করা যায়।

Persistent মেসেজের বৈশিষ্ট্য:

  • ডাটাবেস বা ফাইল সিস্টেমে সংরক্ষণ: মেসেজগুলি সিস্টেমের স্থায়ী স্টোরেজে (যেমন, ডাটাবেস বা ফাইল সিস্টেম) সংরক্ষিত হয়।
  • নির্ভরযোগ্যতা: সিস্টেম যদি ক্র্যাশ হয় বা পুনরায় চালু হয়, তবুও মেসেজগুলো ফিরে পাওয়া সম্ভব।
  • কম পারফরম্যান্স: মেসেজকে স্টোরেজে সেভ করার কারণে এটি কিছুটা বেশি সময় নিতে পারে, যার ফলে পারফরম্যান্সে কিছুটা প্রভাব পড়ে।

উদাহরণ

import javax.jms.*;

public class PersistentMessageProducer {
    public static void main(String[] args) throws JMSException {
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
        Connection connection = connectionFactory.createConnection();
        connection.start();

        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        Destination destination = session.createQueue("TEST_QUEUE");

        MessageProducer producer = session.createProducer(destination);
        producer.setDeliveryMode(DeliveryMode.PERSISTENT);  // Persistent Delivery Mode

        TextMessage message = session.createTextMessage("This is a persistent message.");
        producer.send(message);

        System.out.println("Persistent message sent: " + message.getText());

        connection.close();
    }
}

উপরের কোডে, মেসেজটির ডেলিভারি মোড Persistent হিসেবে সেট করা হয়েছে, যার ফলে মেসেজটি ডাটাবেসে বা ফাইল সিস্টেমে সংরক্ষিত হবে।


Non-persistent Message Delivery Mode

Non-persistent মেসেজ ডেলিভারি মোডে, মেসেজটি পাঠানোর পর তা কোন স্থায়ী স্টোরেজে সংরক্ষিত হয় না। এটি শুধুমাত্র মেমরি বা টেম্পোরারি স্টোরেজে রক্ষা পায় এবং সিস্টেম বন্ধ বা ক্র্যাশ হলে মেসেজটি হারিয়ে যায়। এই মোডটি সাধারণত পারফরম্যান্স বৃদ্ধি করতে ব্যবহৃত হয়, কারণ এতে ডেটা স্টোরেজের জন্য অতিরিক্ত সময় লাগে না।

Non-persistent মেসেজের বৈশিষ্ট্য:

  • মেমরিতে সংরক্ষণ: মেসেজগুলি মেমরি বা অন্যান্য টেম্পোরারি স্টোরেজে সংরক্ষিত থাকে।
  • নির্ভরযোগ্যতা কম: সিস্টেম ক্র্যাশ হলে মেসেজগুলি হারিয়ে যাবে।
  • উচ্চ পারফরম্যান্স: মেসেজটি দ্রুত পাঠানো হয় কারণ এটি ডাটাবেস বা স্থায়ী স্টোরেজে সেভ করা হয় না।

উদাহরণ

import javax.jms.*;

public class NonPersistentMessageProducer {
    public static void main(String[] args) throws JMSException {
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
        Connection connection = connectionFactory.createConnection();
        connection.start();

        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        Destination destination = session.createQueue("TEST_QUEUE");

        MessageProducer producer = session.createProducer(destination);
        producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);  // Non-persistent Delivery Mode

        TextMessage message = session.createTextMessage("This is a non-persistent message.");
        producer.send(message);

        System.out.println("Non-persistent message sent: " + message.getText());

        connection.close();
    }
}

উপরের কোডে, মেসেজটির ডেলিভারি মোড Non-persistent হিসেবে সেট করা হয়েছে, যার ফলে মেসেজটি মেমরিতে সংরক্ষিত হবে এবং সিস্টেম বন্ধ হলে তা হারিয়ে যাবে।


Persistent এবং Non-persistent মেসেজের তুলনা

বৈশিষ্ট্যPersistent (স্থায়ী)Non-persistent (অস্থায়ী)
সংরক্ষণডাটাবেস বা ফাইল সিস্টেমে সংরক্ষিতমেমরি বা টেম্পোরারি স্টোরেজে সংরক্ষিত
নির্ভরযোগ্যতাউচ্চ (মেসেজ ক্র্যাশ বা রিস্টার্টের পরও পাওয়া যায়)কম (ক্র্যাশ হলে মেসেজ হারিয়ে যায়)
পারফরম্যান্সকম (স্টোরেজে সেভ করতে সময় নেয়)উচ্চ (দ্রুত মেসেজ প্রেরণ)
ব্যবহারগুরুত্বপূর্ণ ডেটা বা মেসেজ যেখানে ডাটা হারানো যাবে নাকম গুরুত্বপূর্ণ ডেটা যেখানে দ্রুত প্রক্রিয়াকরণ প্রয়োজন

সারাংশ

অ্যাপাচি অ্যাকটিভএমকিউ মেসেজ ডেলিভারি মোড দুটি প্রদান করে: Persistent এবং Non-persistentPersistent মোড মেসেজগুলো স্থায়ীভাবে সংরক্ষণ করে এবং সিস্টেমের রিস্টার্টের পরও তা পুনরুদ্ধার করা যায়, তবে এতে কিছুটা কম পারফরম্যান্স পাওয়া যায়। অপরদিকে, Non-persistent মোডে মেসেজগুলি দ্রুত প্রেরিত হয়, কিন্তু সিস্টেম বন্ধ হলে তা হারিয়ে যায়। অ্যাপ্লিকেশন বা সিস্টেমের প্রয়োজন অনুযায়ী মেসেজ ডেলিভারি মোড নির্বাচন করা উচিত।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion